﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "/common/link.ftl">

</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm" >
                    <input type="hidden" name="id" value="${employee.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="username" value="${employee.username}"
                                   placeholder="请输入用户名"
                                    <#if employee??>
                                        disabled
                                    </#if>
                            >
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="name" value="${employee.name}" placeholder="请输入真实姓名">
                        </div>
                    </div>
                    <#if !employee??>
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                        </div>
                    </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control"  name="email" value="${employee.email}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="age" value="${employee.age}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#list departments as d>
                                    <option value="${d.id}">${d.name}</option>
                                </#list>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox" ${(employee.admin)?then('checked','')}>
                        </div>
                    </div>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list employee.roles as e>
                                        <option value="${e.id}">${e.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="button" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">
</div>
<script>
    // 角色框移动
    function moveSelected(src,target) {
        $('.' + target).append($('.' + src + '> option:selected'));
    }
    function moveAll(src,target) {
        $('.' + target).append($('.' + src + '> option'));
    }



    var arr = [];
    $('.selfRoles > option').each(function (i, ele) {
        arr.push($(ele).val());
    });

    $('.allRoles > option').each(function (i, ele) {
       let id = $(ele).val();
       if ($.inArray(id,arr) > -1) {
           $(ele).remove();
       }
    });

    $('.btn-submit').click(function () {
        $('.selfRoles > option').prop('selected',true);
        $('#editForm').submit();
    });

    let roleDiv;
    $('#admin').click(function () {
        let temp = $(this).prop('checked');
        if (temp) {
            roleDiv = $('#roleDiv').detach();
        }else {
            $('#adminDiv').after(roleDiv);
        }
    });

    $(function () {
        let temp = $('#admin').prop('checked');
        if (temp) {
            $('#roleDiv').detach();
        }
    })

    // 找到表单,并调用验证插件提供的方法来初始化验证规则
    $('#editForm').bootstrapValidator({
        fields: {
            username: {// input 中的 name 对应的值
                validators: {// 不能为空,并且长度时2-8个字符串
                    notEmpty: {
                        message: '用户名不能为空'
                    },
                    stringLength: {
                        min: 2,
                        max: 8
                    },
                    remote: { //远程验证
                        type: 'POST', //请求方式
                        url: '/employee/checkName', //请求地址
                        message: '用户名已经存在', //验证不通过时的提示信息
                        delay: 500, //输入内容2秒后发请求
                        /* data: function() {  //自定义提交多个参数，默认只会提交当前用户名input的参数
                          return {
                              id: $('[name="id"]').val(),
                              username: $('[name="username"]').val()
                          };
                      },*/
                    }
                }
            },
            password: {// input 中的 password 对应的值
                validators: {
                    notEmpty: {
                        message: '密码不能为空'
                    },
                }
            },
            repassword: {// input 中的 password 对应的值
                validators: {
                    identical: {
                        field: 'password',
                        message: '两次输入的密码必须相同'
                    }
                }
            },
            email: {// input 中的 email 对应的值
                validators: {
                    emailAddress: {}
                }
            },
            age: {// input 中的 age 对应的值
                validators: {
                    regexp: {
                        regexp: /^[0-9_\.]+$/,
                        message: '请输入正确的年龄'
                    }
                }
            },
        }
    }).on('success.form.bv', function () {
        $('#editForm').ajaxSubmit(function (data) {
            if (data.success) {
                Swal.fire({
                    title: '保存成功',
                    icon: 'success',
                    confirmButtonTest: 'OK',
                }).then((result) => {
                    if (result.value) {
                        window.location.href = '/employee/list';
                    }
                })
            } else {
                Swal.fire(
                    data.msg,
                    '',
                    'error'
                )
            }
        });
    })

</script>
</body>
</html>
